<template>
  <div class="user-profile">
    <!-- 顶部信息 -->
    <van-nav-bar
      title="个人信息"
      left-arrow
      @click-left="$router.back()"
      class="page-nav-bar"
    ></van-nav-bar>
    <!-- 顶部信息 -->

    <!-- 选择文件 -->
    <input
      type="file"
      hidden
      ref="file"
      @change="onFileChange"
      multiple="false"
    />
    <!-- 选择文件 -->

    <!-- 头像 -->
    <van-cell title="头像" is-link @click="$refs.file.click()">
      <van-image slot="default" class="avatar" round :src="user.photo" />
    </van-cell>
    <!-- 头像 -->

    <!-- 昵称 -->
    <van-cell
      title="昵称"
      :value="user.name"
      is-link
      @click="isUpdateNameShow = true"
    ></van-cell>
    <!-- 昵称 -->

    <!-- 性别 -->
    <van-cell
      @click="isUpdateGenderShow = true"
      title="性别"
      :value="user.gender === 0 ? '男' : '女'"
      is-link
    ></van-cell>
    <!-- 性别 -->

    <!-- 生日 -->
    <van-cell
      title="生日"
      :value="user.birthday"
      is-link
      @click="isUpdateBirthdayShow = true"
    ></van-cell>
    <!-- 生日 -->

    <!-- 修改昵称 -->
    <van-popup
      v-model="isUpdateNameShow"
      style="height: 100%"
      position="bottom"
    >
      <UpdateName
        v-model="user.name"
        @close="isUpdateNameShow = false"
        v-if="isUpdateNameShow"
      />
    </van-popup>
    <!-- 修改昵称 -->

    <!-- 修改性别 -->
    <van-popup v-model="isUpdateGenderShow" position="bottom">
      <UpdateGender
        v-model="user.gender"
        @close="isUpdateGenderShow = false"
        v-if="isUpdateGenderShow"
      />
    </van-popup>
    <!-- 修改性别 -->
    <!-- 修改年龄 -->
    <van-popup v-model="isUpdateBirthdayShow" position="bottom">
      <UpdateBirthday
        v-model="user.birthday"
        @close="isUpdateBirthdayShow = false"
        v-if="isUpdateBirthdayShow"
      />
    </van-popup>
    <!-- 修改年龄 -->

    <!-- 修改头像 -->
    <van-popup
      v-model="isUpdatePhotoShow"
      position="bottom"
      style="height: 100%"
    >
      <UpdatePhoto
        :img="img"
        @close="isUpdatePhotoShow = false"
        v-if="isUpdatePhotoShow"
        @update-photo="user.photo = $event"
      />
    </van-popup>
    <!-- 修改头像 -->
  </div>
</template>

<script>
import UpdateName from './components/UpdateName'
import UpdateGender from './components/UpdateGender'
import UpdateBirthday from './components/UpdateBirthday'
import UpdatePhoto from './components/UpdatePhoto'
export default {
  name: 'UserProfile',
  components: { UpdateName, UpdateGender, UpdateBirthday, UpdatePhoto },
  data() {
    return {
      user: {}, // 用户信息
      isUpdateNameShow: false, // 修改昵称弹层
      isUpdateGenderShow: false, // 修改性别弹层
      isUpdateBirthdayShow: false, // 修改生日弹层
      isUpdatePhotoShow: false, // 修改头像弹层
      img: null // 预览的图片
    }
  },
  methods: {
    async loadUserProfile() {
      try {
        const { data: res } = await this.$api.getUSerProfile()
        console.log(res)
        this.user = res.data
      } catch (err) {
        console.log(err)
        this.$toast('获取失败')
      }
    },
    onFileChange() {
      const file = this.$refs.file.files[0]
      this.img = window.URL.createObjectURL(file)
      // 展示预览图片弹出层
      this.isUpdatePhotoShow = true
      // file-input 如果选了同一个文件不会触发 change
      // 解决办法就是每次使用完毕，把它的 value 清空
      this.$refs.file.value = ''
    }
  },
  created() {
    this.loadUserProfile()
  }
}
</script>

<style lang="less" scoped>
.user-profile {
  .avatar {
    width: 60px;
    height: 60px;
  }
}
</style>
